<template>
    <div v-loading="loading" style="background-color: #fff; padding: 10px; border-radius: 5px;">
        <el-form :model="form" label-width="160px">
            <el-tabs v-model="activeName">
                <el-tab-pane label="注册与访问" name="first">
                    <el-form-item label="是否允许注册会员">
                        <el-radio-group v-model="form.open_reg">
                            <el-radio :label="0" border>
                                关闭
                            </el-radio>
                            <el-radio :label="1" border>
                                开启
                            </el-radio>
                        </el-radio-group>
                    </el-form-item>
                    <el-form-item label="注册类型">
                        <el-radio-group v-model="form.reg_method">
                            <el-radio label="username" border>
                                普通注册
                            </el-radio>
                            <el-radio label="phone" border>
                                手机注册
                            </el-radio>
                        </el-radio-group>
                    </el-form-item>
                    <el-form-item label="密码最小长度">
                        <el-input v-model="form.password_min" placeholder="密码最小长度" style="width: 30%;"
                            type="number"></el-input>
                    </el-form-item>
                    <el-form-item label="强制密码复杂度">
                        <el-checkbox-group v-model="form.password_encrypt">
                            <el-checkbox label="0" border>数字</el-checkbox>
                            <el-checkbox label="1" border>小写字母</el-checkbox>
                            <el-checkbox label="2" border>大写字母</el-checkbox>
                            <el-checkbox label="3" border>符号</el-checkbox>
                        </el-checkbox-group>
                    </el-form-item>
                </el-tab-pane>
                <el-tab-pane label="上传设置" name="second">
                    <el-form-item label="默认上传方式">
                        <el-radio-group v-model="form.upload_method">
                            <el-radio label="oss" border>
                                对象存储
                            </el-radio>
                        </el-radio-group>
                    </el-form-item>
                    <el-form-item label="Bucket">
                        <el-input v-model="form.upload_config.Bucket" placeholder="Bucket" style="width: 30%;"></el-input>
                    </el-form-item>
                    <el-form-item label="ACCESS_KEY">
                        <el-input v-model="form.upload_config.ACCESS_KEY" placeholder="ACCESS_KEY"
                            style="width: 30%;"></el-input>
                    </el-form-item>
                    <el-form-item label="SECRET_KEY">
                        <el-input v-model="form.upload_config.SECRET_KEY" placeholder="SECRET_KEY"
                            style="width: 30%;"></el-input>
                    </el-form-item>
                    <el-form-item label="空间域名">
                        <el-input v-model="form.upload_config.http" placeholder="空间域名" style="width: 30%;"></el-input>
                        <small style="color: #464646; display: flex; margin-top: 5px;">请补全 http:// 或 https://</small>
                    </el-form-item>
                </el-tab-pane>
                <el-tab-pane label="Api安全" name="third">
                    <el-form-item label="是否开启API安全">
                        <el-radio-group v-model="form.api_safe">
                            <el-radio :label="0" border>
                                关闭
                            </el-radio>
                            <el-radio :label="1" border>
                                开启
                            </el-radio>
                        </el-radio-group>
                        <small style="color: #6b6b6b; display: flex; margin-top: 5px;">api安全功能开启之后调用前端api需要传输签名串</small>
                    </el-form-item>
                    <el-form-item label="秘钥">
                        <el-input v-model="form.api_secret" placeholder="秘钥" style="width: 30%;"></el-input>
                        <small
                            style="color: #6b6b6b; display: flex; margin-top: 5px;">秘钥设置关系系统中api调用传输签名串的编码规则，以及会员token解析，请慎重设置，注意设置之后对应会员要求重新登录获取token</small>
                    </el-form-item>
                </el-tab-pane>
            </el-tabs>
            <el-form-item>
                <el-button type="primary" size="default" @click="submit">保存</el-button>
            </el-form-item>
        </el-form>
    </div>
</template>
<script setup>
import { ref, reactive } from "vue"
import { getSysconfig, setSysconfig } from "@/api/sysconfig"
import { elNotification } from "@/hooks/elNotification.js";

const activeName = ref("first")

const form = reactive({
    "open_reg": 1, //开启注册，0关闭1开启
    "reg_method": "username", //注册方式，username普通phone手机
    "password_min": 7, //密码最小长度
    "password_encrypt": [], //密码复杂度，0数字、1小写字母、2大写字母、3符号；例如0,1,2
    "upload_method": "oss", //上传方式，oss对象存储
    "upload_config": {
        "Bucket": "",
        "ACCESS_KEY": "",
        "SECRET_KEY": "",
        "http": ""
    }, //上传配置 { Bucket:"", ACCESS_KEY:"", SECRET_KEY:"", http:""}
    "api_safe": 1, //api安全，0关闭1开启
    "api_secret": "", //秘钥
})

const loading = ref(false)
function getData() {
    loading.value = true
    getSysconfig().then(res => {
        for (const k in form) {
            form[k] = res[k]
        }
        form.password_encrypt = form.password_encrypt.split(",")
    }).finally(() => {
        loading.value = false
    })
}

getData()

const submit = () => {
    loading.value = true
    setSysconfig({
        ...form,
        password_encrypt: form.password_encrypt.join(",")
    }).then(res => {
        elNotification("修改成功")
        getData()
    }).finally(() => {
        loading.value = false
    })
}
</script>